# Digital Systems Design and Laboratory [13. Analysis of Clocked Sequential Circuits]

Chung-Wei Lin

cwlin@csie.ntu.edu.tw

CSIE Department

National Taiwan University

Spring 2019

#### Outline

- **☐** A Sequential Parity Checker
- ☐ Analysis by Signal Tracing and Timing Charts
- ☐ State Tables and Graphs
- ☐ General Models for Sequential Circuits

### Parity Checker (1/3)

#### Error detection

- > Add an extra bit (parity bit) when transmitting or storing binary data
- ➤ When the total number of 1 bits in the block (data bits + parity bit) is odd (even), we say the parity is odd (even)

| Even Parity |   | Odd Parity |   |
|-------------|---|------------|---|
| 0000000     | 0 | 0000000    | 1 |
| 0000001     | 1 | 0000001    | 0 |
| 0110110     | 0 | 0110110    | 1 |
| 1010101     | 0 | 1010101    | 1 |
| 0111000     | 1 | 0111000    | 0 |

# Parity Checker (2/3)

- ☐ Design an odd-parity checker
  - $\triangleright$  Z = 1 if total # of 1's is odd
  - $\triangleright$  Z = 0 if total # of 1's is even
    - $Z = 0 \rightarrow$  an error occurs in odd-parity protocol
    - Initially, Z = 0
- ☐ Timing chart of the odd parity checker (falling-edge triggered)





## Parity Checker (3/3)

☐ State graph





☐ State table

| Present        | Next State     |                | Present    |   |
|----------------|----------------|----------------|------------|---|
| State          | X = 0          | X = 1          | Output (Z) | ı |
| S <sub>0</sub> | S <sub>0</sub> | S <sub>1</sub> | 0          | ı |
| $S_1$          | $S_1$          | $S_0$          | 1          |   |

| 0 | Q <sup>+</sup> |       | Present    |
|---|----------------|-------|------------|
| Q | X = 0          | X = 1 | Output (Z) |
| 0 | 0              | 1     | 0          |
| 1 | 1              | 0     | 1          |

#### Outline

- ☐ A Sequential Parity Checker
- Analysis by Signal Tracing and Timing Charts
- ☐ State Tables and Graphs
- ☐ General Models for Sequential Circuits

#### Analysis of Clocked Sequential Circuits

- ☐ Find the output sequence resulting from a given input one
  - > Draw a timing chart to show inputs, clock, flip-flop states, outputs
  - 1. Assume an initial state of flip-flops (reset to 0)
  - 2. Determine the circuit outputs and flip-flop inputs for 1st input pattern
  - 3. Determine the new flip-flop states after the next active clock edge
  - 4. Determine the outputs for the new states
  - 5. Repeat 2--4 for each input pattern



#### Type I: Moore Machine

- ☐ Moore machine: the output depends only on the present state
  - The output which corresponds to a given input appears until after the active clock edge



X = 01101

A = 010101

B = 001111

Z = 011010

### Type II: Mealy Machine

- Mealy machine: the output depends on both the present state and on the inputs
  - > False outputs may occur
    - Glitches and spikes





$$A = 000110$$

$$B = 011110$$

$$Z = 11001$$

#### Outline

- ☐ A Sequential Parity Checker
- ☐ Analysis by Signal Tracing and Timing Charts
- ☐ State Tables and Graphs
- ☐ General Models for Sequential Circuits

#### How to Construct the State Table?

- ☐ Procedure to construct the state table for a given circuit
  - 1. Determine the flip-flop input equations and the output equations from the circuit
  - 2. Derive the next-state equation for each flip-flop from its input equations
  - 3. Plot a next-state map for each flip-flop
  - 4. Combine these maps to form the state table
- ☐ Recap: next-state equations

| Туре           | Q <sup>+</sup> |
|----------------|----------------|
| D Flip-Flop    | D              |
| S-R Flip-Flop  | S + R'Q        |
| J-K Flip-Flop  | JQ' + K'Q      |
| T Flip-Flop    | TQ' + T'Q      |
| D-CE Flip-Flop | D(CE) + Q(CE)' |

## Example: Moore Machine (1/3)

- ☐ Procedure to construct the state table for a given circuit
  - 1. Determine the flip-flop input equations and the output equations from the circuit
    - $D_A = X \oplus B'$ ,  $D_B = A + X$ ,  $Z = A \oplus B$
  - 2. Derive the next-state equation for each flip-flop from its input equations
    - $A^+ = X \oplus B', B^+ = A + X$



## Example: Moore Machine (2/3)

#### ☐ Procedure to construct the state table for a given circuit

• 
$$A^+ = X \oplus B', B^+ = A + X$$

3. Plot a next-state map for each flip-flop

4. Combine these maps to form the state table

| ΔD | A <sup>+</sup> | Z     |   |
|----|----------------|-------|---|
| AB | X = 0          | X = 1 | Z |
| 00 | 10             | 01    | 0 |
| 01 | 00             | 11    | 1 |
| 11 | 01             | 11    | 0 |
| 10 | 11             | 01    | 1 |



## Example: Moore Machine (3/3)

#### ☐ Procedure to construct the state table for a given circuit

4. Combine these maps to form the state table

|    | A <sup>+</sup> | ·R+   |   |
|----|----------------|-------|---|
| AB |                |       | Z |
|    | X = 0          | V - I |   |
| 00 | 10             | 01    | 0 |
| 01 | 00             | 11    | 1 |
| 11 | 01             | 11    | 0 |
| 10 | 11             | 01    | 1 |

| Present        | Next           | 7              |   |
|----------------|----------------|----------------|---|
| State          | X = 0          | X = 1          | Z |
| S <sub>0</sub> | S <sub>3</sub> | S <sub>1</sub> | 0 |
| $S_1$          | $S_0$          | S <sub>2</sub> | 1 |
| S <sub>2</sub> | $S_1$          | S <sub>2</sub> | 0 |
| S <sub>3</sub> | $S_2$          | $S_1$          | 1 |



## Example: Mealy Machine (1/3)

- ☐ Procedure to construct the state table for a given circuit
  - 1. Determine the flip-flop input equations and the output equations from the circuit
    - $J_A = XB$ ,  $K_A = X$ ,  $J_B = X$ ,  $K_B = XA$ , Z = XB' + XA + X'A'B
  - 2. Derive the next-state equation for each flip-flop from its input equations
    - $A^+ = J_{\Delta}A' + K_{\Delta}'A = XA'B + X'A$
    - $B^+ = J_B B' + K_B' B = XB' + (XA)' B = XB' + X'B + A'B$



# Example: Mealy Machine (2/3)

☐ Procedure to construct the state table for a given circuit

• 
$$A^{+} = XA'B + X'A$$

• 
$$B^+ = XB' + X'B + A'B$$

• 
$$Z = XB' + XA + X'A'B$$

- 3. Plot a next-state map for each flip-flop
- 4. Combine these maps to form the state table

| AB | A <sup>+</sup> B <sup>+</sup> |       | Z     |       |
|----|-------------------------------|-------|-------|-------|
| Ab | X = 0                         | X = 1 | X = 0 | X = 1 |
| 00 | 00                            | 01    | 0     | 1     |
| 01 | 01                            | 11    | 1     | 0     |
| 11 | 11                            | 00    | 0     | 1     |
| 10 | 10                            | 01    | 0     | 1     |



# Example: Mealy Machine (3/3)

#### ☐ Procedure to construct the state table for a given circuit

4. Combine these maps to form the state table

| AB | A <sup>+</sup> B <sup>+</sup> |       | Z     |       |
|----|-------------------------------|-------|-------|-------|
| Ab | X = 0                         | X = 1 | X = 0 | X = 1 |
| 00 | 00                            | 01    | 0     | 1     |
| 01 | 01                            | 11    | 1     | 0     |
| 11 | 11                            | 00    | 0     | 1     |
| 10 | 10                            | 01    | 0     | 1     |

| <b>A</b> D     | A <sup>+</sup> B <sup>+</sup> |       | Z     |       |
|----------------|-------------------------------|-------|-------|-------|
| AB             | X = 0                         | X = 1 | X = 0 | X = 1 |
| S <sub>0</sub> | S <sub>0</sub>                | $S_1$ | 0     | 1     |
| $S_1$          | S <sub>1</sub>                | $S_2$ | 1     | 0     |
| S <sub>2</sub> | S <sub>2</sub>                | $S_0$ | 0     | 1     |
| S <sub>3</sub> | S <sub>3</sub>                | $S_1$ | 0     | 1     |



### Example: Multiple Inputs and Outputs



#### Outline

- ☐ A Sequential Parity Checker
- ☐ Analysis by Signal Tracing and Timing Charts
- ☐ State Tables and Graphs
- ☐ General Models for Sequential Circuits

#### General Model for Moore Machines

☐ An output is a function of only states



#### General Model for Mealy Machines

☐ An output is a function of states and inputs



# Q&A

#### Announcement (0520)

- ☐ Homework policy
  - ➤ You are encouraged to work on homework in study groups, but you must write up the solutions on your own
- ☐ Homework 4
  - > Due at noon on Jun 3
- ☐ Plan from now
  - ➤ May 20: Lab 2 + Short Talk by Prof. Jie-Hone Jiang
  - ➤ May 27: Lecture (+ Short Talk by Prof. Chien-Mo Li)
  - > Jun 3: Lab 1 and Lab 2 Demo
  - > Jun 10: Lecture
  - ➤ Jun 17: Final Exam

#### Announcement (0527)

- ☐ Homework 4 + Lab 2
  - Due at noon on Jun 3
- ☐ Plan from now
  - ➤ May 27: Lecture
  - > Jun 3: Lab 1 and Lab 2 Demo
    - Schedule by the last digits of student IDs
    - 1:20-1:50pm: 0 and 1 (9 students)
    - 1:50-2:20pm: 2 and 3 (11 students)
    - 2:20-2:50pm: 4 and 5 (10 students)
    - 2:50-3:20pm: 6 (12 students)
    - 3:20-4pm: 7, 8, and 9 (17 students)
  - ➤ Jun 10: Lecture
  - > Jun 17: Final Exam
- Student evaluation